在 JSX 中通过大括号使用 JavaScript – React

您所在的位置:网站首页 img css样式 在 JSX 中通过大括号使用 JavaScript – React

在 JSX 中通过大括号使用 JavaScript – React

2023-03-24 20:09| 来源: 网络整理| 查看: 265

JSX 允许你在 JavaScript 中编写类似 HTML 的标记,从而使渲染的逻辑和内容可以写在一起。有时候,你可能想要在标记中添加一些 JavaScript 逻辑或者引用动态的属性。这种情况下,你可以在 JSX 的大括号内来编写 JavaScript。

You will learn 如何使用引号传递字符串 在 JSX 的大括号内引用 JavaScript 变量 在 JSX 的大括号内调用 JavaScript 函数 在 JSX 的大括号内使用 JavaScript 对象 使用引号传递字符串

当你想把一个字符串属性传递给 JSX 时,把它放到单引号或双引号中:

Forkexport default function Avatar() { return ( ); }

这里的 "https://i.imgur.com/7vQD0fPs.jpg" 和 "Gregorio Y. Zara" 就是被作为字符串传递的。

但是如果你想要动态地指定 src 或 alt 的值呢?你可以 用 { 和 } 替代 " 和 " 以使用 JavaScript 变量 :

Forkexport default function Avatar() { const avatar = 'https://i.imgur.com/7vQD0fPs.jpg'; const description = 'Gregorio Y. Zara'; return ( ); }

请注意 className="avatar" 和 src={avatar} 之间的区别,className="avatar" 指定了一个就叫 "avatar" 的使图片在样式上变圆的 CSS 类名,而 src={avatar} 这种写法会去读取 JavaScript 中 avatar 这个变量的值。这是因为大括号可以使你直接在标签中使用 JavaScript!

使用大括号:一扇进入 JavaScript 世界的窗户

JSX 是一种编写 JavaScript 的特殊方式。这为在大括号 { } 中使用 JavaScript 带来了可能。下面的示例中声明了科学家的名字,name,然后在 后的大括号内嵌入它:

Forkexport default function TodoList() { const name = 'Gregorio Y. Zara'; return ( {name}'s To Do List ); }

试着将 name 的值从 'Gregorio Y. Zara' 更改成 'Hedy Lamarr'。看看这个 To Do List 的标题将如何变化?

大括号内的任何 JavaScript 表达式都能正常运行,包括像 formatDate() 这样的函数调用:

Forkconst today = new Date(); function formatDate(date) { return new Intl.DateTimeFormat( 'en-US', { weekday: 'long' } ).format(date); } export default function TodoList() { return ( To Do List for {formatDate(today)} ); } 可以在哪使用大括号

在 JSX 中,只能在以下两种场景中使用大括号:

用作 JSX 标签内的文本:{name}'s To Do List 是有效的,但是 Gregorio Y. Zara's To Do List 无效。 用作紧跟在 = 符号后的 属性:src={avatar} 会读取 avatar 变量,但是 src="{avatar}" 只会传一个字符串 {avatar}。 使用 “双大括号”:JSX 中的 CSS 和 对象

除了字符串、数字和其它 JavaScript 表达式,你甚至可以在 JSX 中传递对象。对象也用大括号表示,例如 { name: "Hedy Lamarr", inventions: 5 }。因此,为了能在 JSX 中传递,你必须用另一对额外的大括号包裹对象:person={{ name: "Hedy Lamarr", inventions: 5 }}。

你可能在 JSX 的内联 CSS 样式中就已经见过这种写法了。React 不要求你使用内联样式(使用 CSS 类就能满足大部分情况)。但是当你需要内联样式的时候,你可以给 style 属性传递一个对象:

Forkexport default function TodoList() { return ( Improve the videophone Prepare aeronautics lectures Work on the alcohol-fuelled engine ); }

试着更改一下 backgroundColor 和 color 的值。

当你写成这样时,你可以很清楚地看到大括号里包着的对象:

所以当你下次在 JSX 中看到 {{ 和 }}时,就知道它只不过是包在大括号里的一个对象罢了!

Pitfall

内联 style 属性 使用驼峰命名法编写。例如,HTML 在你的组件里应该写成 。

JavaScript 对象和大括号的更多可能

你可以将多个表达式合并到一个对象中,在 JSX 的大括号内分别使用它们:

Forkconst person = { name: 'Gregorio Y. Zara', theme: { backgroundColor: 'black', color: 'pink' } }; export default function TodoList() { return ( {person.name}'s Todos Improve the videophone Prepare aeronautics lectures Work on the alcohol-fuelled engine ); }

在这个示例中,person JavaScript 对象包含 name 中存储的字符串和 theme 对象:

const person = { name: 'Gregorio Y. Zara', theme: { backgroundColor: 'black', color: 'pink' }};

该组件可以这样使用来自 person 的值:

{person.name}'s Todos

JSX 是一种模板语言的最小实现,因为它允许你通过 JavaScript 来组织数据和逻辑。

Recap

现在你几乎了解了有关 JSX 的一切:

JSX 引号内的值会作为字符串传递给属性。 大括号让你可以将 JavaScript 的逻辑和变量带入到标签中。 它们会在 JSX 标签中的内容区域或紧随属性的 = 后起作用。 {{ 和 }} 并不是什么特殊的语法:它只是包在 JSX 大括号内的 JavaScript 对象。 Try out some challengesChallenge 1 of 3: 修复错误

这段代码崩溃了,并打印出这样一个错误 Objects are not valid as a React child:

Forkconst person = { name: 'Gregorio Y. Zara', theme: { backgroundColor: 'black', color: 'pink' } }; export default function TodoList() { return ( {person}'s Todos Improve the videophone Prepare aeronautics lectures Work on the alcohol-fuelled engine ); }

你能找到问题出在哪吗?



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3